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This article presents an iterative technique for simplifying Boolean func- 
tions. The method enables the user to obtain prime implicemts by simple 
operations on a set of decimal numbers which describe the function. This 
technique may be umt for functions of any number of variables. 

At the present time, although several design aids have been iutro- 
duoed, 1 **' 1 (he synthesis of switching circuits remains a highly developed 
art, the theory being of only limited value to the circuit designer. In 
particular, (hat part of the design process involving the simplification of 
Boolean function* having large numbers of variables still presents a 
major problem. 

Probably the liest method currently available for the solution nf such 
problems is the Quine-McCluskey Tabular Method, which consists of 
the exhaustive comparison of terms of Ihe standard sum for adjacencies 
— terms whieh differ in only one variable. This technique, besides lacing 
a long, tedious one, determines all possible prime implicants of (lie given 
function. Thus a second problem is generated — selecting the essential 
prime implicants from among those found. This in itself is often a dif- 
ficult procedure, for which specific methods have been developed. 1 

The method to l>e descried in this paper Ls a simple, iterative tech- 
nique for determining the prime implicants of a Boolean function. All 
of the essential prime implicants are found with this method, and in 
general, some or all of the nonessential prime implicants are auto- 
matically eliminated, materially simplifying the linal search for the es- 
sential prime implicants. 

Any Boolean function, say f(x\ f • ■ * » j„) for example, may l>e ex- 
panded into the form 

¥ 

/(-ri , J-- , ••• , r n ) - jv/O, a*. " " . *■) + *i'"/(0. *t . '•' ■ *.). 
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The above theorem is generally referred to as the expansion theorem 1 
and enables one to expand any n-variable switching function about 
any one of the variables. As shown above the given funetion in said to 
be expanded about the variable n . Two new functions are thus formed, 
one multiplying xi and one multiplying z\. The two new switching 
functions are functions of xj , ■ ■ * ,a only, and are referred to as the 
residues of z% . 

Let us assume that the given function is specified in its canonical form 
as a sum of product terms, 

where Pj represents the general product term and the subscript j is 
the decimal equivalent of the associated product term, when the product 
terms are expressed in binary form with primed literals repliuvd by zeros 
and unprimed literals replaced by ones. This is often written as 

/(xi , x s t - - ■ , x n ) m J^j t t* being implied. 

Assume further that the variables arc assigned binary weights in the 
order shown, with j- 1 teing assigned the highest weight andx fl Ihe lowest 
When the variable weights are assigned in this manner the expansion 
becomes a very simple process. In particular, if a specific series of decimal 
numbers characterizes the function, the residues may be formed as 
follows: 

f(x lt z* f ■■■,*.)- Ei-siA + M'A' 

H? is a sum consisting of the decimal numbers which are smaller than 
the weight of x\ (the variable being expanded about), and R x is a sum 
consisting of the numbers which are greater than the weight of x% , from 
each of which the weight of x x is subtracted. 

Noting that the residues Id and ft 2 arc now each specified by summa- 
tions, and the new sets of decimal numbers are interpreted as being 
functions of all succeeding variables, generically we may write: 

fi - f(xt , xj , ■ ■ , £„). 

Each of the residues can now be expanded about x% , which is the 
highest weighted variable of the residues. Thus the expansion can be 
carried out in this manner using nothing more complicated than the 
subtraction process. 

As an example, assume the following function: 

f{A 7 B t C t D) - £(0,1,8,9,10) = -4ft! + AT?, 
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where the order of the variables (A*B t C,D) indicates I he relative binary 
weights, i.e- t A is the highest weighted and D is the lowest weighted 
variable. 

ft mfiBfifi) = E0,1 and 

ft =f(BX\D) = £(8-8). (9-8), (10-8) - £0,1,2 

since the binary weight of -4 « 8. 

This process mny lie repealed by expanding each of the residues alnui! 
B* At this point lei us examine ft and ft , 

There are live possibilities: 

(a) ft = ft = ft therefore 

f(A % B t (\D) - AB + A'R = B 

indicating that A and A' are redundant 

(b) B\ > ft, indicating that the decimal numbers representing B 2 
form a sulwl of those representing ft , then ft ■ ft + ft , and 

S(A ,5,0,0) = i4(ft + ft) + il'ft - dft + AB b + A'ft = ft + -!/?, . 

(c) ft > R, t when ft = ft + ft. 
f(A f Bfi,D) = ARi + .4'(ft + ft) - 

,4 ft + .4'ft + A'ft - B x + d'Jfc - 

(d) The residues have no numl)ers in common, in which case 

f{Afififi) - AR { + A'R*. 

(e) Some of the numbers in each residue are the same, 

R , = ft + ft , ft - ft + ft and 
J{AJBflJD)-A(IL+ ft) + .4 '(ft + ft) 
- AR,+ .4ft + 4'ft + -4'ft 
= ft + -4ft + -4'ft. 
Note that in (his case the function may be written as 

f{A t B,(\D) = ft + A (ft + ft) + ,4 '(ft + ft) 

The summation ft may l>e included with A and A' as a redundancy. 
This is significant in the method to l>e shown, because ft may con- 
tribute to the simplification of residues resulting from subsequent 
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expansion. This Ls analogous lo using a term of the standard sum in 
more than one subcube when using a Karnaugh map. 1 

The following method employs all of the above ideas and will be shown 
by means of an example. 

Assume a function 

f(A t B t C,D) = £1,2,3,4^7,8,9,11,12,13,14, 

Expansion about the variable A —the highest weighted variable — 
yields 

ttAfifiJft = A'<E W,4,6,7) + A(Z 0,1,3,4,5,6) 

= Z 1,3,4,6 + A' (2 1,2,3,4,6,7) + ^<E 0,1,3,4,5,0)- 

Where tlie summation £ 1,3,4,6 is that part of the A residues which 
are the same, note that the numbers 1,3,4,6 are now redundant in the 
summations multiplying ,4 and -4'. The summation 1,3,4,6 actually 
represents tbon terms of the standard sum whieh differ only in (he A 
variable. 

There are now three summations, eaeh of whieh is a function of B t C 9 D 
only- Each of these functions must now lie expanded about the variable 
B. These operations are repeated exactly until the expansion about all 
variables is complete. 

At this point the alxive illustration will be repeated, showing a 

meehanieal technique to organize and simplify the procedure. Refer to 

Fig. L 
Step 1- Arrange the decimal numbers representing the given function 

in a column. 

Step 2. Divide the decimal numbers into two columnar groups, one 
headed with A r and one headed with A. The A' column contains the 
numbers of the original function which are Miinller than 8 — the binary 
weight of A — and the -4 column contains the numliers which are equal 
to or greater than 8, first subtracting 8 from each- 
Step 3- Include a third column, headed by a dash to indicate the 
redundancy of A and A\ consisting of the numbers which arc common to 
columns -4 and A\ Check the corresponding numbers in columns .1 and 
A 9 to record the fact that they are redundant- If any of the numbers in 
the dashed column have been previously checked in both the A and A* 
columns, they should also be checked in the dashed column. 

Step 4- Examine each column. If any column consists of only checked 
numbers, eliminate the column entirely. 

Each of the columns must now Ix* expanded about B by repeating the 
above steps. The expansion of the function in the A f column is shown in 



SIMPLIFYING HOOLKAN FUNCTIONS 



1341 



Kig- lb* Since the weight of B is 4, all numbers less than 4 arc placed 
in the U' column. These numbers are 1,2,3. Note that 1 and 3 must Ik; 
cheeked since they were previously cheeked in the A' column. The num- 
bers 4,6,7 are placed in the Ii column, first subtracting 4 from each, giving 
0,2,3. The numbers 0,2 which correspond to 4,6 must be checked. A 
dashed column consisting of the numbers 2,3 is now included. Check the 
numbers 2,3 in botli the B and H' columns. All of the numbers in the It 
and B' columns are now checked, hence both columns may be eliminated 
u» shown. 

Figure 2 illustrates the complete development. When the function is 
expanded about the linul variable, note that the residues must be 0. 
At this point the prime implicants may be determined by simply tracing 
ft path back to the start and reading the appropriate columnar headings. 

Not all of the prime implirnnts obtained may be required to describe 
the function. In the example just shown, all of the prime implicants were 
essential, but another example will l>e shown in which this is not the 
case. 

/= X;0,I/>AI,<V7,8,9,1U* 

This function is simplified in Kig. 3, and four prime implicants are 
obtained, not all of which are essential. A simple method fur determining 
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Fir. 1 - Kxnmple 1 :/(•■! t fi f C,D) - L 1,2,3,4,0.7,8,9,11,12,13,14; (a) expansion 
about A f (b> expansion alwml B t 
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f {A.6,C,D,) * E »ii*»»4A7*MplMt|l»fM - A'C+AC'+B'D + BD F 

Pig. 2 — Example 1 completed* 

the essential prime implicunts ifl available in a prime implieant chart 
first proposed by Quine and later simplified by McCluskey, Such a eharl 
is shown in Fig. 4 for ihe example of Fig. 3 (see Ref. I). 

The ehart requires the establishment of columns, eaeh of which repre- 
sents one of the decimal numbers of the original function and is so 
headed. Each row represents one of the p;ime implicanta and is thus 
identified. 

Each prime implieant is a combination of 2* of the decimal numbers 
of the original function; k may be any integer, including zero. It is an 
easy matter to find these numbers. One could, for example, Imx back- 
ward from the final residue of the prime implieant (always zero) and if 
a column is passed through which is headed by an unprimed variable 
add ihe weight of the variable, if through a primed column the number 
remains unchanged. When tracing through a column headed by a dash 
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Kin. 3 — Example 2:f(A t H>L\D) - £ 0,1,2,3,4,0,7,8,9,11, 15; example yielding 
iioncimetititil prime iniplicantfl* 

each number becomes two numbers, one of which is the same as the 
number in the dashed column. The other number is obtained by adding 
the weight of the variable from whose expansion the dashed column re- 
sulted. 

On each row of the chart, mark a cross under the decimal numbers 

12346789 II 15 
—* ® ®-« A'D' (0,2,4,61* 



\ i i * B'D (1,3,9,11) 
A ® it ®-CD (3,7,11,15)* 



B'C'to, !,•■■)* 

{I 



*PR*UARY OASIS ROW = ESSENTIAL TERM 
f (A,B,C,D>] ■ £0,1,2,3,4,6,7,3,9,11,15- A'D'+B'C+CD 

Fig. 4 — Chart method of obtaining oiwntial prime implicant* (or Kxamplc 2* 
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associated with the terms contained in the prime implicant represented 
by that row. Then scan the columns and circle the crosses which stand 
alone in a column, and rule a line through each associated row. Such rows 
represent essential prime implicants. Now rule a vertical line through 
each cross in the ruled rows. If all other crosses in the chart are not thus 
ruled out by the vertical lines, additional prime implicants must be 
chosen. (See Ref. 1 for further discussion of prime implicant charts.) 
The chart of Fig. 4 shows that A'D*, B'C\ and CD are essential and the 
function may therefore be expressed by the following minimum sum 

fiAfififi) == A'D' + B'C + CD. 

If the function of Fig. 3 is simplified by other tabular methods, it will 
be noted that there are six possible prime implicants. This illustrates 
an important advantage of the method described here, and this is that 
while all essential prime implicants are obtained, some or all of the non- 
essential prime implicants may be eliminated automatically, materially 
simplifying the search for the essential terms by- charting. The missing 
prime implicants are actually included in columns which were crossed 
out in the development because all elements were checked, indicating 
that the prime implicants if obtained would he redundant. 

There art* functions for which, if all possible prime implicants arc 
found, charts would be produced which are cyclic in form. There arc 
no immediately apparent choices of prime implicants which would yield 
a minimum sum. In such cases some initial choice must l>e made, and 
some cut and try is necessary. In fact, there will generally be more than 
one equally satisfactory solution, depending upon the initial choice. 

When the method described in this paper is applied to functions which 
would normally produce a cyclical prime implicant chart, the chart 
obtained will not be cyclical- Some of the prime implicants will be elim- 
inated as the work progresses, in effect making the initial choices auto- 
matically. This has two results, 'the chart is materially simplified and 
the solution is easily and automatically obtained. However if a particular 
initial choice would result in a more economical solution than another, 
then this method may or may not obtain the minimum sum, depending 
upon the weighting of the variables. The final solution in such cases 
must lie regarded as an approximation to the minimum sum. The ap- 
proximation will always be a close one. 

If some of the decimal numbers specifying the given function are 
"don't care" terms, they must be checked initially and subsequently 
treated like any other checked number. The only real difference is noted 
when drawing a prime implicant chart, where columns corresponding 
to "don't eare" terms would not l>o included (Refs. 1, 4). 
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A final example is included in Figure 5 to indicate which of the decimal 
numbers of the given function arc combined to obtain any particular 
number in the expansion. The decimal numbers of the given function 
are shown parenthetically. 

In conclusion the method described above offers the following ad- 
vantages: 

(a) The decimal numbers specifying the function may be operate 
on directly without any preliminary grouping. 
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AB = £ 12,13,14,15* 



f (A,B.C,0} = E 2,3,10,11,12,13,14,15 + Z$ 1.6,7 
= C + AB 



Fig. 5 — Example 3: /M,HX\«) = £ 1,-2,3,6,7,10,11,12,13,14,15; number* in 
]■-:■■ ro»1 \r-t-- are decimal numbers which were combined to give numbers in expan- 
sion. 
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(b) Adjaeencies (terms which differ in only one variable) are found 
in groups, making litis method very rapid in use. 

(c) The operations are simple and iterative, enabling functions hav- 
ing any number of variables to be simplified. 

(d) Some nonessential prime implicants will in general be eliminated, 
simplifying the prime implicant chart, 
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